<?php

namespace Fruitcake\Cors;

use Asm89\Stack\CorsService;
use Illuminate\Foundation\Application as LaravelApplication;
use Illuminate\Support\ServiceProvider as BaseServiceProvider;
use Laravel\Lumen\Application as LumenApplication;

class CorsServiceProvider extends BaseServiceProvider
{
    /**
     * Register the service provider.
     *
     * @return void
     */
    public function register()
    {
        $this->mergeConfigFrom($this->configPath(), 'cors');

        $this->app->singleton(CorsService::class, function ($app) {
            $config = $app['config']->get('cors');

            // Convert case to supported options
            $options = [
                'supportsCredentials' => $config['supports_credentials'],
                'allowedOrigins' => $config['allowed_origins'],
                'allowedOriginsPatterns' => $config['allowed_origins_patterns'],
                'allowedHeaders' => $config['allowed_headers'],
                'allowedMethods' => $config['allowed_methods'],
                'exposedHeaders' => $config['exposed_headers'],
                'maxAge' => $config['max_age'],
            ];

            // Transform wildcard pattern
            foreach ($options['allowedOrigins'] as $origin) {
                if (strpos($origin, '*') !== false) {
                    $options['allowedOriginsPatterns'][] = $this->convertWildcardToPattern($origin);
                }
            }

            return new CorsService($options);
        });
    }

    /**
     * Register the config for publishing
     *
     */
    public function boot()
    {
        if ($this->app instanceof LaravelApplication && $this->app->runningInConsole()) {
            $this->publishes([$this->configPath() => config_path('cors.php')]);
        } elseif ($this->app instanceof LumenApplication) {
            $this->app->configure('cors');
        }
    }

    /**
     * Set the config path
     *
     * @return string
     */
    protected function configPath()
    {
        return __DIR__ . '/../config/cors.php';
    }

    /**
     * Create a pattern for a wildcard, based on Str::is() from Laravel
     *
     * @see https://github.com/laravel/framework/blob/5.5/src/Illuminate/Support/Str.php
     * @param string $pattern
     * @return string
     */
    protected function convertWildcardToPattern($pattern)
    {
        $pattern = preg_quote($pattern, '#');

        // Asterisks are translated into zero-or-more regular expression wildcards
        // to make it convenient to check if the strings starts with the given
        // pattern such as "library/*", making any string check convenient.
        $pattern = str_replace('\*', '.*', $pattern);

        return '#^' . $pattern . '\z#u';
    }
}
